<?
include_once("./_common.php");

//$wr = sql_fetch(" select * from $write_table where wr_id = $wr_id ");

@include_once("$board_skin_path/delete.head.skin.php");

if ($is_admin == "super") // 최고관리자 통과
    ;
else if ($is_admin == "group") { // 그룹관리자
    $mb = get_member($write[mb_id]);
    if ($member[mb_id] != $group[gr_admin]) // 자신이 관리하는 그룹인가?
        alert("자신이 관리하는 그룹의 게시판이 아니므로 삭제할 수 없습니다.");
    else if ($member[mb_level] < $mb[mb_level]) // 자신의 레벨이 크거나 같다면 통과
        alert("자신의 권한보다 높은 권한의 회원이 작성한 글은 삭제할 수 없습니다.");
} else if ($is_admin == "board") { // 게시판관리자이면
    $mb = get_member($write[mb_id]);
    if ($member[mb_id] != $board[bo_admin]) // 자신이 관리하는 게시판인가?
        alert("자신이 관리하는 게시판이 아니므로 삭제할 수 없습니다.");
    else if ($member[mb_level] < $mb[mb_level]) // 자신의 레벨이 크거나 같다면 통과
        alert("자신의 권한보다 높은 권한의 회원이 작성한 글은 삭제할 수 없습니다.");
} else if ($member[mb_id]) {
    if ($member[mb_id] != $write[mb_id])
        alert("자신의 글이 아니므로 삭제할 수 없습니다.");
} else {
    if ($write[mb_id])
        alert("로그인 후 삭제하세요.", "./login.php?url=".urlencode("./board.php?bo_table=$bo_table&wr_id=$wr_id"));
    else if (sql_password($wr_password) != $write[wr_password])
        alert("패스워드가 틀리므로 삭제할 수 없습니다."); 
}

$len = strlen($write[wr_reply]);
if ($len < 0) $len = 0; 
$reply = substr($write[wr_reply], 0, $len);

$write[wr_id]+=0;
$write[wr_num]+=0;

// 원글만 구한다.    
$sql = " select count(*) as cnt from $write_table ".
       " where wr_reply like ? ".
       " and wr_id <> ? ".
       " and wr_num = ? ".
       " and wr_is_comment = ? ";
$row = sql_prepare_fetch(
		$sql,
		array("{$reply}%", $write[wr_id], $write[wr_num], 0));
if ($row[cnt] && !$is_admin)
    alert("이 글과 관련된 답변글이 존재하므로 삭제 할 수 없습니다.\\n\\n우선 답변글부터 삭제하여 주십시오.");

// 코멘트 달린 원글의 삭제 여부
$sql = " select count(*) as cnt from $write_table ".
       " where wr_parent = ? ".
       " and mb_id <> ? ".
       " and wr_is_comment = ? ";
$row = sql_prepare_fetch(
		$sql,
		array($wr_id, "$member[mb_id]", 1));
if ($row[cnt] >= $board[bo_count_delete] && !$is_admin)
    alert("이 글과 관련된 코멘트가 존재하므로 삭제 할 수 없습니다.\\n\\n코멘트가 {$board[bo_count_delete]}건 이상 달린 원글은 삭제할 수 없습니다.");

// 사용자 코드 실행
@include_once("$board_skin_path/delete.skin.php");


// 나라오름님 수정 : 원글과 코멘트수가 정상적으로 업데이트 되지 않는 오류를 잡아 주셨습니다.
//$sql = " select wr_id, mb_id, wr_comment from $write_table where wr_parent = '$write[wr_id]' order by wr_id ";
$sql = " select wr_id, mb_id, wr_is_comment from $write_table where wr_parent = $write[wr_id] order by wr_id ";
$rows = sql_fetch_rows($sql);

for ($i=0; $i < count($rows); $i++)
{
	$row = $rows[$i];
	
    // 원글이라면
    if (!$row[wr_is_comment]) 
    {
        // 원글 포인트 삭제
        if (!delete_point($row[mb_id], $bo_table, $row[wr_id], '쓰기'))
            insert_point($row[mb_id], $board[bo_write_point] * (-1), "$board[bo_subject] $row[wr_id] 글삭제");
		
		$row[wr_id]+=0;
		
        // 업로드된 파일이 있다면 파일삭제
        $rows2 = sql_prepare_fetch_rows(
        	"select * from $g4[board_file_table] where bo_table = ? and wr_id = ? ",
        	array("$bo_table", $row[wr_id]));
        for ($j=0; $j < count($rows2); $j++) {
        	$row2 = $rows2[$j];
            @unlink("$g4[path]/data/file/$bo_table/$row2[bf_file]");
        }
            
        // 파일테이블 행 삭제
        sql_prepare_execute(
        	" delete from $g4[board_file_table] where bo_table = ? and wr_id = ? ",
        	array("$bo_table", $row[wr_id]), 1, 1);

        $count_write++;
    } 
    else 
    {
        // 코멘트 포인트 삭제
        if (!delete_point($row[mb_id], $bo_table, $row[wr_id], '코멘트'))
            insert_point($row[mb_id], $board[bo_comment_point] * (-1), "$board[bo_subject] {$write[wr_id]}-{$row[wr_id]} 코멘트삭제");

        $count_comment++;
    }
}

// 게시글 삭제
sql_prepare_execute(
	" delete from $write_table where wr_parent = ? ",
	array($write[wr_id]), 1, 1);

// 최근게시물 삭제
sql_prepare_execute(
	" delete from $g4[board_new_table] where bo_table = ? and wr_parent = ? ",
	array("$bo_table", $write[wr_id]), 1, 1);

// 스크랩 삭제
sql_prepare_execute(
	" delete from $g4[scrap_table] where bo_table = ? and wr_id = ? ",
	array("$bo_table", $write[wr_id]), 1, 1);
	
// 공지사항 정보 삭제
$notice_array = explode("\n", trim($board[bo_notice]));
$bo_notice = "";
for ($k=0; $k<count($notice_array); $k++)
    if ((int)$write[wr_id] != (int)$notice_array[$k])
        $bo_notice .= $notice_array[$k] . "\n";
$bo_notice = trim($bo_notice);
sql_prepare_execute(
	" update $g4[board_table] set bo_notice = ? where bo_table = ? ",
	array("$bo_notice", "$bo_table"), 1, 1);

$count_write += 0;
$count_comment += 0;


// 글숫자 감소
if ($count_write > 0 || $count_comment > 0) {
    sql_prepare_execute(
    	" update $g4[board_table] set bo_count_write = bo_count_write - ?, bo_count_comment = bo_count_comment - ? where bo_table = ? ",
    	array($count_write, $count_comment, "$bo_table"), 1, 1);
}

@include_once("$board_skin_path/delete.tail.skin.php");

goto_url("./board.php?bo_table=$bo_table&page=$page" . $qstr);
?>
